* {
  margin: 0;
  padding: 0;
}
ul {
  list-style: none;
}
@keyframes ball01 {
  to {
    transform: translateX(160px);
    opacity: 0.2;
  }
}
@keyframes ball02 {
  to {
    transform: translateX(-160px);
    opacity: 0.2;
  }
}
@keyframes ripples {
  from {
    opacity: 1;
  }
  to {
    width: 160px;
    height: 160px;
    border: 15px solid #fff;
    opacity: 0;
  }
}
@keyframes waiting {
  to {
    transform: rotate(360deg);
  }
}
.w_h_anim {
  width: 315px;
  height: 210px;
  border-radius: 10px;
}
.w_h_ball {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #fff;
}
.box {
  width: 1065px;
  height: 230px;
  margin: 200px auto;
  background-color: #000;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  border-radius: 20px;
}
.box .anim1 {
  width: 315px;
  height: 210px;
  border-radius: 10px;
  background-color: #4ad3b4;
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.box .anim1 .left {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #fff;
  animation: ball01 0.5s infinite alternate;
}
.box .anim1 .right {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #fff;
  animation: ball02 0.5s infinite alternate;
}
.box .anim2 {
  width: 315px;
  height: 210px;
  border-radius: 10px;
  background-color: #f9553f;
  position: relative;
}
.box .anim2 div {
  position: absolute;
  width: 10px;
  height: 10px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 1px solid #fff;
  box-sizing: border-box;
  background-color: rgba(255, 255, 255, 0);
  opacity: 0;
}
.box .anim2 div:nth-child(1) {
  animation: ripples 1s infinite;
}
.box .anim2 div:nth-child(2) {
  animation: ripples 1s 0.33333333s infinite;
}
.box .anim2 div:nth-child(3) {
  animation: ripples 1s 0.66666667s infinite;
}
.box .anim2 div:nth-child(4) {
  animation: ripples 1s 1s infinite;
}
.box .anim3 {
  width: 315px;
  height: 210px;
  border-radius: 10px;
  background-color: #ab96d9;
  position: relative;
  overflow: hidden;
}
.box .anim3 .out_box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 113px;
  height: 113px;
  background-color: rgba(255, 255, 255, 0.5);
  border-radius: 50%;
  border: 157.5px solid #ab96d9;
}
.box .anim3 .inner_box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 107px;
  height: 107px;
  background-color: #ab96d9;
  border-radius: 50%;
}
.box .anim3 .progress_box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 103px;
  height: 103px;
  background-color: #fff;
  transform-origin: top left;
  transform: rotate(0deg);
  animation: waiting 1s infinite linear;
}
